.page {
  display: flex;
  flex-direction: column;
  height: 100vh;
}

.header {
  display: flex;
  height: var(--header-height);
  line-height: var(--header-height);
  color: var(--indigo-50);
  background-color: var(--indigo-950);
  border-bottom: 1px solid var(--indigo-900);
}

.logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: var(--side-width);
  cursor: pointer;
}

.title {
  flex: auto;
  display: flex;
  justify-content: center;
  font-family: "kuhei";
  font-size: 2.125rem;
  letter-spacing: 0.5rem;
}

.tools {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--side-width);
}

.container {
  flex: auto;
  display: flex;
}

.aside {
  flex: 0 0 var(--side-width);
  padding: 16px 12px;
  background-color: var(--indigo-950);
}

.menu {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.menuItem {
  display: flex;
  align-items: center;
  gap: 12px;
  height: var(--menu-item-height);
  padding: 0 12px;
  color: var(--indigo-50);
  text-decoration: none;
  background: var(--indigo-950);
  border-radius: 8px;
  transition: background-color 0.2s ease-in-out;
}

.menuItem.active {
  background: var(--indigo-900);
}

.menuItem:hover {
  background: var(--indigo-700);
  cursor: pointer;
}

.main {
  flex: auto;
  display: flex;
  flex-direction: column;
  padding: 12px;
  gap: 12px;
  background-color: var(--indigo-100);
}
